**9. 3bit Controlled up / down synchronous counter with preset & clear.**

**AIM : -S**imulation of **3 bit Connter** using Behavioral modeling.

**OBJECTIVE:** T**o** learn behavioral modeling style. Its uses and different types of declarations with some different types of circuits. Structure of VHDL program is well discussed with this modeling style

**THEORY :-**

**Behavioral style:-**

Highest level of abstraction supported in VHDL is called the behavior level of abstraction. In it we have for loop, while loop, If then else, case &variable assignment. The statements are enclosed in a PROCESS block, & are executed sequentially.

In it circuit is described in terms of its operation overtime.

In behavioral description, the concept of time may be expressed precisely, with actual delays between related events (such as the propagation delays within gates & on wires.) or it may be simply an ordering of operation that are expressed sequentially (such as in a functional description of a F/F).

A behavioral design method defines a circuit in terms of text language rather than a schematic of interconnected symbols.

Behavioral design is a technology independent, text based design that incorporates high level functionality & high level information flow.

**Structure of Behavioral modeling:**

**![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAR4AAADZAgMAAACLPbf9AAAAAXNSR0IArs4c6QAAAAlwSFlzAAAOaQAADk0B2ugvKQAAAAlQTFRFAAAAADAA////Ivx3VAAABSFJREFUaN7tm89uqzoQxhGrI57iqKvK72NL8T4L/BQoq8p7vLgrZMnVME95Z8y/5DRpA/a95fZCQ0oo/GrP2F8+sCkwz9IVTZFjKTOCLllq1vw+QCtAvUH3Hrf+mv4qaPVXR0+H2qt94i7IxS39CCRuQfCwRJgKkuZkZH/WThqFbS1dX597jdBgI2yFpUdR0LFQIpS8k0DwC4uuagjeiBnUSy1r+lGO3lCeGCSDQhBC2MYD0ItKQ5+QtuhXRQXtAF9pF73sAjJahbrWzrnQ11prAmkXqOh0lPV+AAFagRb4fDrVgsdX2sWspWpB60A4BsnaIINMKzGeYz1SkfwIovpNIOw+guRDUFFZ3xVA6wDik0cQVK9QVLcx0guIkxdBDmOJ0HrruUR4t2qcyZsYaYpRBNUxRoFKFDCGhqME9MJHMboGUdV6yaCWs6ZlSx8oa90IukRQzJrteFfMmocPWUPpNEquWuB2RIU51YbakS+xQGG7FxDUhLCh/979ItDQjqB8/bMdbVogU++3PgcICuoeh9RuArGk3QjabkDpVTtzh1Ban1QiSOqguOdKmQjSyoVA+qFCaoxcKwNGedsNyGEWkFZtjFEyaMpaMmhqR6mguISkHnINkplAvTR5QLsStv8ACMY3kQryI8h+F4i6iNOt6RUqMrgt2RByIexpV4OkbjV1XNlLNriKDaJAsq9+g4wMUtLXZN4cWw3BDm01iIRtEDdZU+U4Nl0iiJ0yhWpziehbZFTJxKpJOvkm2B62BZvSjzfph1KILek3dxokd4/9gCbrm9xpD4V8GGy9O1B61Q4z+q+CDjP6TKc9zOgB4tuak5QAelg2hw2LwuJ7eApUL6DLRxAQyD0FoiLNZ798BPmnQf1Z4XBviG+I0gHirYJffJcsgiyB5Lk1wTj5NYgMVleI0UvYi/cddsQsGEa75ZnNa3vbgO/EyOBksIabj9ZbrpoY9tEvF9jWtf3XICxnEEJ1B4Rk69wToGYpEZY2ASSWGF1XbYoRgzQ+Cfo8RkjfX0+BLlcgitGYtQnUnpGy9lSMXpYYFXzPd25HERQIRO3oC9ChRwdoaERrLtc+BVWZQJBYogaHyyvvqbemgISgS+yoGCswd0Dcy6thMxk0KcZ+SpQvRiMiDTSN4KWDGlxASe3oetkfaF96tCeQ/qmglq1Gr9NB0pAdCyoZxOPa2rmQDuIbEtjKLCA20RmqhrpXLj1rPImA3Hh6jLJlLV87OvToACFbv1we0vtMIJ49kwKazSiBbApoNqMWkoK9WL900AjYUYnyxWgwWImgxYyuao+fmVGoDjP6fwVp+r41mUAyE2ilJ71nIk4KlcaTDGkgaSSPHyeD4kTUUGu+Q5gG4vmjPLSRDCIPmQfE4zU5qsYeMnCwV47/3PWQgdOfDLqq5e5A74ew/XMg/RNBsyrq4IJGuqbFloduzVrQpIp8xdeqnj4aqVq5GjSromqDobWOc37c+k67qCK/08pzfnDD99o9EMdoPWiW1wlksI9zrNaCJnml+GCMkd4Wo1leKWuYkrVZXqkdYVI7etS2dwdaI9qH1H4TSA9j6OJHgSbNfqughI4uRYXvqm4DaNLsi/cAleDpAdZvAM2azY9PxQd7GLSharPU8vg3z4SlIolEUFMQqKjsMHq0vmo4lyg+R0V1W5u7W80eHjKjMr3h8HzT+qwNml0NIIigLemfNPu36CoPWIoLNmIL6O4CuwP5XKDvE7Y8T/gWGUGwOxDmWbq/ARtXTinP7JexAAAAAElFTkSuQmCC)**

**9. 3bit Controlled up / down synchronous counter with preset & clear.**

**Functional block diagram of 3 bit controlled up / down synchronous counter with preset & clear:**

**Function table of 3 bit controlled up / down synchronous counter with preset & clear:**

**Design steps:**

* Click on Xilinx ISE 9.2i.
* Create New project from file menu. Ensure top level source is HDL.
* Select family of devices (usually spartan2E or 3)
* Ensure preferred language is VHDL.
* Click new source which shows you project details, device details
* and Synthesis and simulator tools.
* After finishing project create new source by right clicking in project name with VHDL module.
* Complete ports name, directions and bus. Ensure architecture name is behavioral.
* After that we will get design summary and detailed reports.
* Close design summary.
* Create your code with given modeling style.
* Go to process window and synthesis to check if any error is there in code. Check syntax and view RTL schematic. Create new source to simulate the code
* Right click on source name and create test bench waveform with proper name. Ensure the project is same.
* Click on combinational circuit in initial timing wizard.
* Select test bench wave in source window. Apply inputs to wave diagram. Ensure you are in behavioral simulation.

Go to process box. Click on Xilinx ISE simulator and simulate the model.

**RTL Schematic:**

**Timing Diagram**

**9. 3bit Controlled up / down synchronous counter with preset & clear.**

**INPUT:**

* Clock, Preset, Clear

**OUTPUT:**

* Three output lines,

**FAQ’s:**

1. Explain the structure of behavioral modeling?

**![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAR4AAADZAgMAAACLPbf9AAAAAXNSR0IArs4c6QAAAAlwSFlzAAAOaQAADk0B2ugvKQAAAAlQTFRFAAAAADAA////Ivx3VAAABSFJREFUaN7tm89uqzoQxhGrI57iqKvK72NL8T4L/BQoq8p7vLgrZMnVME95Z8y/5DRpA/a95fZCQ0oo/GrP2F8+sCkwz9IVTZFjKTOCLllq1vw+QCtAvUH3Hrf+mv4qaPVXR0+H2qt94i7IxS39CCRuQfCwRJgKkuZkZH/WThqFbS1dX597jdBgI2yFpUdR0LFQIpS8k0DwC4uuagjeiBnUSy1r+lGO3lCeGCSDQhBC2MYD0ItKQ5+QtuhXRQXtAF9pF73sAjJahbrWzrnQ11prAmkXqOh0lPV+AAFagRb4fDrVgsdX2sWspWpB60A4BsnaIINMKzGeYz1SkfwIovpNIOw+guRDUFFZ3xVA6wDik0cQVK9QVLcx0guIkxdBDmOJ0HrruUR4t2qcyZsYaYpRBNUxRoFKFDCGhqME9MJHMboGUdV6yaCWs6ZlSx8oa90IukRQzJrteFfMmocPWUPpNEquWuB2RIU51YbakS+xQGG7FxDUhLCh/979ItDQjqB8/bMdbVogU++3PgcICuoeh9RuArGk3QjabkDpVTtzh1Ban1QiSOqguOdKmQjSyoVA+qFCaoxcKwNGedsNyGEWkFZtjFEyaMpaMmhqR6mguISkHnINkplAvTR5QLsStv8ACMY3kQryI8h+F4i6iNOt6RUqMrgt2RByIexpV4OkbjV1XNlLNriKDaJAsq9+g4wMUtLXZN4cWw3BDm01iIRtEDdZU+U4Nl0iiJ0yhWpziehbZFTJxKpJOvkm2B62BZvSjzfph1KILek3dxokd4/9gCbrm9xpD4V8GGy9O1B61Q4z+q+CDjP6TKc9zOgB4tuak5QAelg2hw2LwuJ7eApUL6DLRxAQyD0FoiLNZ798BPmnQf1Z4XBviG+I0gHirYJffJcsgiyB5Lk1wTj5NYgMVleI0UvYi/cddsQsGEa75ZnNa3vbgO/EyOBksIabj9ZbrpoY9tEvF9jWtf3XICxnEEJ1B4Rk69wToGYpEZY2ASSWGF1XbYoRgzQ+Cfo8RkjfX0+BLlcgitGYtQnUnpGy9lSMXpYYFXzPd25HERQIRO3oC9ChRwdoaERrLtc+BVWZQJBYogaHyyvvqbemgISgS+yoGCswd0Dcy6thMxk0KcZ+SpQvRiMiDTSN4KWDGlxASe3oetkfaF96tCeQ/qmglq1Gr9NB0pAdCyoZxOPa2rmQDuIbEtjKLCA20RmqhrpXLj1rPImA3Hh6jLJlLV87OvToACFbv1we0vtMIJ49kwKazSiBbApoNqMWkoK9WL900AjYUYnyxWgwWImgxYyuao+fmVGoDjP6fwVp+r41mUAyE2ilJ71nIk4KlcaTDGkgaSSPHyeD4kTUUGu+Q5gG4vmjPLSRDCIPmQfE4zU5qsYeMnCwV47/3PWQgdOfDLqq5e5A74ew/XMg/RNBsyrq4IJGuqbFloduzVrQpIp8xdeqnj4aqVq5GjSromqDobWOc37c+k67qCK/08pzfnDD99o9EMdoPWiW1wlksI9zrNaCJnml+GCMkd4Wo1leKWuYkrVZXqkdYVI7etS2dwdaI9qH1H4TSA9j6OJHgSbNfqughI4uRYXvqm4DaNLsi/cAleDpAdZvAM2azY9PxQd7GLSharPU8vg3z4SlIolEUFMQqKjsMHq0vmo4lyg+R0V1W5u7W80eHjKjMr3h8HzT+qwNml0NIIigLemfNPu36CoPWIoLNmIL6O4CuwP5XKDvE7Y8T/gWGUGwOxDmWbq/ARtXTinP7JexAAAAAElFTkSuQmCC)**

1. What are the differences between behavioral and structural modeling?

**Ans:** Behavioral descriptionof a circuit is the highest level of abstraction in VHDL. Here, the circuit is described in terms of it operation with respect to time. All operations are in one level of code. The operations are described in a way that the designer of a sequential circuit infers a register

Structural description***,*** on the other hand, is a circuit description in terms of its components. it can either create a low level description, much like a hierarchy in a block diagram. Whenever you see a *component* instantiated in a code, that code employs structural description of the circuit. The components are connected in the form of a *netlist*. This is for better manageability and reusability

1. What are the differences between behavioral and data flow modeling?

**Ans:** Behavioral – describes how the output is derived from the inputs using structured statements.

Dataflow – describes how the data flows from the inputs to the output most often

using NOT, AND and OR operations

1. What do you mean by *process* statement?

**Ans:** The process statement begins with the PROCESS keyword, followed by a parenthesized list of signals, called the sensitivity list. It operates on selected and conditional statements.

**9. 3bit Controlled up / down synchronous counter with preset & clear.**

1. Explain syntax of *process* statement?

**Ans: BEGIN**

**Process( sensitivity list)**

**;**

**;**

**END process;**

**PRACTICE ASSIGNMENTS:**

1. Implement 3 bit asynchronous up counter using behavioral modeling.

2. Implement 3 bit asynchronous down counter using behavioral modeling.

3. Implement 3 bit synchronous down counter using behavioral modeling.